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PREDICTIVE ROUTING TABLE CACHE POPULATION 

Cross-Reference to Related Applications 

This application claims the benefit of U.S. Provisional Application No. 60/208,888, filed 
June 1, 2000, which provisional application is incorporated by reference. 

Field of the Invention 

The present invention relates to telecommunications and computer networks in general, and, 
more particularly, to the design of a router for use in a packet network. 

Background of the Invention 

In a packet network, the finite speed of light and the finite speed at which a router can operate 
precludes the traversal of a packet from one side of the network to another instantaneously. Therefore, 
there is always some delay between when a transmitting network termmal transmits a packet and when 
the receiving network terminal receives the packet. 

In some cases, this delay is unimportant. For example, some data (e.^., most e-mail messages, 
etc.) is not perishable or highly time-sensitive and the sender and receiver of the data might consider it 
unimportant whether the packet takes 5 milliseconds, 5 seconds or even 5 minutes to traverse the 
network. In contrast, other data {e.g., voice, full-motion video, instant messaging, etc) is perishable or 
highly time-sensitive, and, therefore, the sender and receiver of the data might consider it very 
important that the packets traverse the network quickly. 

When packet networks were originally conceived and designed and constructed, little or no 
consideration was given to ensuring that a fixed number of packets could be sent across a packet 
network with a maximum delay. Average delays were considered, and packet networks were 
engineered to consider average delays, but little or no consideration was given to engineering the 
maximum delay. Increasingly, however, packet networks are being considered for carrying time- 
sensitive data for applications such as Internet telephony and television broadcasting. 

Perhaps the most significant source of delay in a packet network is due to the speed at which 
the routers operate. It is well known in the prior art how to make and use fast routers, but their extra 
speed comes at a price, and, therefore, it is not typically economical to build them. In fact, it is well 
known in the prior art how to trade cost for performance when designing and building routers. 

Nevertheless, the need exists for a router that is more powerfiil than comparatively expensive 
routers in the prior art. 
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Summary of the Invention 

The present invention is a router and routing table cache population technique that avoids 
some of the costs and disadvantages associated with techniques in the prior art In particular, the 
illustrative embodiment routes packets through it more quickly than comparatively expensive routers 
5 in the prior art. 

The present invention recognizes that a router with a small routing table cache can be fast if 
the routing table cache has a high hit ratio, and that a high hit ratio can be achieved by predicting 
which entries will be needed in the routmg table cache in the future and by populating the routing table 
cache with those entries before they are needed . In accordance with the illustrative embodiment of the 

10 present invention, this is accomplished by: (i) building one or more temporal models of the occurrence 
of needed entries based on empirical data, (ii) by using the temporal model(s) to predict which entries 
are most likely to be needed at some time in the future, and (iii) by populating the router table cache 
with those entries before they are needed. 

The illustrative embodiment of the present invention comprises: an input port for receiving a 

15 succession of packets, wherein each of the packets comprises a destination address; a plurality of 
output ports; a switching fabric for interconnecting the input port to each of the plurality of output 
ports; a processor or building a temporal model of the occurrence of the destination addresses at the 
input port, for populating the routing table cache based on the temporal model and at least one entry 
that is stored in a routing table, and for routing at least one of the packets from the input port to one of 

20 the output ports through the switching fabric based on the entry that is stored in the routing table 
cache. 

Brief Description of the Drawings 

FIG. 1 depicts a block diagram of the salient components of a router in accordance with the 
illustrative embodiment of the present invention. 
25 FIG. 2 depicts a block diagram of the salient components of input port 101, which is a 

component of the router in FIG. 1. 

FIG. 3 is a graph that depicts the relationship of the hit ratio of routing table cache 203 as a 
function of the number of entries in routing table cache 203. 

FIG. 4 is a graph that depicts the relationship of the average search time for routmg table 
30 cache 203 as a function of the number of entries in routing table cache 203. 
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FIG. 5 depicts a flowchart of the salient steps performed by router 100 each time it receives 
and routes a packet. 

FIG. 6 depicts a flowchart of the steps involved in periodically or sporadically generating a 
temporal model, as depicted in FIG. 5. 

5 Detailed Description 

FIG. 1 depicts a block diagram of the salient components of a router in accordance with the 
illustrative embodiment of the present invention. Because the nomenclature of packet networking is 
not well standardized, a router is sometimes called a "packet switch," a "datagram switch," a "cell 
switch," an "ATM switch," a "gateway," a "firewall," or a "bridge" depending on the purpose for 

10 which the router is being used and on the educational and industrial background of the person using 
the term. However, for the purposes of this specification, a "router" is defined as a switch that is 
capable of receiving one or more packets, each of which comprises a destination address, and of 
routing each packet to an output port based on that destination address. 

Router 100 comprises: input port 101, a plurality of output ports, output port 102-1 through 

15 102-7, switching fabric 103, and router table 104, all interconnected as shown. Some embodiments of 
the present invention have more than one input port, and in those cases each input port works in the 
same manner as input port 101 and each contends with the others for access to routing table 104. 

As is clear to those skilled in the art, switching fabric 103 is a space-division switch or a time- 
division switch or any combination of space-division switches and time-division switches (e,g.^ a 

20 space-time-space-division switch, etc) that is capable of transporting a packet fi-om input port 101 to 
one of output ports 102-1 through 102-/ under the direction of input port 101. It will be clear to those 
skilled in the art how to make and use switching fabric 103. 

Routing table 104 is a table that contains a plurality of entries. For the purpose of this 
specification, an "entry" is defined as a mapping of one or more network addresses to one or more 

25 output ports of a router. When an entry maps a network address to more than one of a router's output 
ports, the entry might implicitly or explicitly prioritize those output ports so that, for example, if one is 
congested, another might be used. Table 1 depicts an illustrative portion of routing table 104 that 
contains five illustrative entries, wherein the destination addresses are depicted in IPv4 dotted-decimal 
notation. The first four illustrative entries (/.e., 110.23.43.15/102-73, 110.23.43.16/102-13, 

30 1 10.23.43.17/102-44, and 1 10.23.43.18/102-26) are illustrative of individual network addresses. The 
fifth illustrative entry (z.e., 1 12.7.1 1 l.x/102-15) is illustrative of an entry in which more than one 
network address is mapped to one of a router's output ports. It will be clear to those skilled in the art 
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how to make and use embodiments of the present invention with other network addresses in other 
formats such as IPv6. 



Network Address 


Output Port 






110.23.43.15 


102-73 


110.23.43.16 


102-13 


110.23.43.17 


102-44 


110.23.43.18 


102-26 






112.7.111.x 


102-15 







Table 1 — Portion of Routing Table 104 

Routing table 104 can comprise a large number of entries (e.g., thousands, millions, billions, etc.), and 
5 therefore, whether routing table 104 resides in random access memory (e.g., semiconductor memory, 
etc.) or not (e.g., hard disk, etc.), the shear number of entries in routing table 104 can cause the process 
of looking up a needed entry to be slow regardless of the data structure employed for stormg the 
entries. Furthermore, when an embodiment of the present invention comprises more than one input 
port, the contention among the input ports can exacerbate the average latency associated with the 

10 process of looking up a needed entry in routing table 104. It will be clear to those skilled in the art 
how to make and use routing table 104. 

Output ports 102-1 through 102-7 comprises the interface circuitry for receiving packets from 
switching fabric 103 and for transmitting the departing packets on the appropriate output. It will be 
clear to those skilled in the art how to make and use output ports 102-1 through IO2-7. 

15 FIG. 2 depicts a block diagram of the salient components of input port 101 , which comprises: 

processor 201 and memory 202, which itself comprises routing table cache 203. Processor 201 is a 
special-purpose processor or a general-purpose processor whose instructions are stored in memory 202 
or a combination of the two. Memory 202 is advantageously a small, fast semiconductor memory that 
holds the instructions and data for processor 201. 

20 To ameliorate the latency associated with looking up routing information in routing table 104, 

mput port 101 advantageously comprises routing table cache 203. Routing table cache 203 is a cache 
memory that advantageously holds the most frequently accessed entries of routing table 104. Table 2 
depicts an illustrative portion of routing table cache 203. 
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Network Address 


Output Port 






110.23.43.15 


102-73 


110.23.43.18 


102-26 







Table 2 — Portion of Routing Table Cache 203 

Typically, it is faster for processor 201 to retrieve an entry from routing table cache 203 than it is for 
processor 201 to retrieve the same entry from routing table 104 for three reasons. First, because 
routing table cache 203 is smaller than routing table 104, routing table cache 203 is typically stored in 
5 a physically faster memory than is routing table 104 (e.g. , semiconductor RAM vs. hard disk, etc.). 
Second, processor 201 does not have to contend with other processors for access to routing table cache 
203, whereas processor 201 would have to contend for access to routing table 104 when router 100 
comprises a plurality of input ports. And third, because the number of entries in routing table cache 
203 is typically orders of magnitude smaller than the number of entries in routing table 104, the 
10 process of searching through routing table cache 203 for a needed entry is typically much smaller than 
is the process of searching through routing table 104 for the same entry, regardless of the data 
structure employed. 

It will be clear to those skilled in the art how to decide how many entries routing table cache 
203 should contain. In deciding this number, there are two factors that are advantageously considered. 

15 First, as shown in FIG. 3, as the number of entries in routing table cache 203 increases, the hit 

ratio also increases, albeit with diminishing returns. This suggests that router 100 can be made faster 
by increasing the number of entries in routing table cache 203. For the purposes of this specification, 
the phrase "hit ratio" is defined as the ratio of the number of entries that processor 201 finds in 
routmg table cache 203 divided by the total number of entries that processor 201 needs. 

20 Second, as shown in FIG. 4, as the number of entries in routing table cache 203 increases, the 

time it takes processor 201 to search through routing table cache 203 to find a needed entry also 
increases. This suggests that router 100 can be made faster by decreasing the number of entries in 
routing table cache 203. 

Although these two factors might seem to cancel each other, in general, the speed of router 

25 100 is improved by having a small cache that is populated so as to have as high a hit ratio as possible. 
The illustrative embodiment of the present invention seeks to have a high hit ratio by 
proactivelv populating routing table cache 203. In particular, the illustrative embodiment populates 
routing table cache 203 by: (i) building a temporal model of the occurrence of needed entries based on 
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empirical data, (ii) by using the temporal model to predict which entries are most likely to be needed 
at some time in the future, and (iii) by populating router table cache 203 with those entries before they 
are needed. This is in contrast to routing table cache population techniques in the prior art that are 
either: (i) random, or (ii) reactive, 
5 A brief discussion of how router 100 would be populated in accordance with some routing 

table cache population techniques in the prior art will facilitate an understanding of how it is populated 
in accordance with the illustrative embodiment and will also assist in understanding the difference 
between the prior art and the illustrative embodiment 

One routing table cache population technique in the prior art is the "random population 

10 technique." In accordance with the random population technique, routing table cache 203 would be 
populated with entries from routing table 104 that were selected at random. In other words, if routing 
table 104 contained n entries, the probability that routing table cache 203 would be populated with any 
given entry would be l/«. Furthermore, in accordance with the random population technique, once 
routing table cache 203 was populated, its contents would not be changed in response to empirical data 

15 on which entries were actually needed. The advantage of the random population technique is that it 
requires little processing overhead, but the disadvantage is that it has a very low hit ratio — so low, in 
fact, that the random population technique is not much better than, and is possibly worse than, having 
no routing table cache at all. 

Another routing table cache population technique in the prior art is the "random replacement 

20 technique." In accordance with this technique, routing table cache 203 would be initially populated 
with entries from routing table 104 that were selected at random. Thereafter, when processor 201 
accessed a particular entry in routing table cache 203 (/.e., a cache hit), processor 201 would do 
nothing to routing table cache 203, but when processor 201 did not find a needed entry in routing table 
cache 203 {i.e., a cache fault) and had to resort to routing table 104 for the entry, processor 201 would 

25 randomly replace an entry in routing table cache 203 with the entry just retrieved from routing table 
104. The theory underlying this technique is based on the recognition that an entry that has been 
needed once is more likely to be needed again than is a randomly-chosen entry, and, therefore, this 
technique seeks to improve the hit ratio (in comparison to the random population technique) by 
seeking to anticipate what entries will be needed in the future. The advantages of the random 

30 replacement technique are that it requires little processing overhead and that it usually has a higher hit 
ratio than the random population technique. It is disadvantageous, however, in that it does not take 
into consideration what entries are deleted and might delete a commonly needed entry. Furthermore, 
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in contrast to the illustrative embodiment of the present invention, the random replacement technique 
is reactive, which means that it would only populate routing table cache 203 with an entry in reaction 
to a need for that entry. That is, it only populates routing table cache 203 with an entry after than 
entry has been needed, in contrast to the present invention which populates routing table cache 203 
5 with entries before they are needed. The random replacement technique is advantageous in that it 
requires little processing overhead, which decreases the average delay through router 100. 

A third replacement technique in the prior art is the "least-recently-used" or "LRU" technique. 
In accordance with the least-recently-used technique, routing table cache 203 would be initially 
populated with entries from routing table 104 that were selected at random. Thereafter, processor 201 

10 would keep track of how recently each entry in routing table cache 203 was accessed. When processor 
201 accesses a particular entry in routing table cache 203 (/.e., a cache hit), that entry would be 
marked as having been recently used, but when processor 201 did not find a needed entry in routing 
table cache 203 (ie., a cache fault) and was forced to resort to routing table 104 for the entry, 
processor 201 would replace the least-recently-used entry in routing table cache 203 with the entry just 

15 retrieved from routing table 104. The theory underlying this technique is based on the recognition that 
an entry that has been recently used is more likely to be needed again than is the least-recently-used 
entry. The least-recently-used technique is advantageous in that it has a high hit ratio relative to all 
known routing table cache replacement techniques in the prior art. The least-recently-used technique 
is disadvantageous in that it requires that processor 201 spend a great deal of time keeping track of 

20 how recently each entry in routing table cache 203 is accessed, which increases the average delay 

through router 100. But like the random population technique and the random replacement technique, 
and in contrast to the illustrative embodiment, the least-recently-used technique is reactive. 

FIG. 5 depicts a flowchart of the operation of the illustrative embodiment of the present 
invention, which seeks to have a high hit ratio by predictively populating routing table cache 203. 

25 At step 501, processor 201 initially populates routing table cache 203 with entries from 

routing table 104 that are selected at random. It will be clear to those skilled in the art how to perform 
step 501, 

At step 502, as input port 101 receives a temporal succession of packets, each of which 
comprises a destination address. As part of step 502, processor 201 examines each packet to 
30 determine the network address to which the packet is addressed. It will be clear to those skilled in the 
art how to perform step 502. 
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At step 503, processor 201 retrieves the routing information for each destination address from 
routing table cache 203, if possible, and from routing table 104, if necessary. For example, if the 
network address to which the packet is addressed is "1 10.23.43.18," then processor 201 only need look 
in routing table cache 203 to determine that the packet is to be transmitted via output port 102-6 (see 
5 Table 2). Alternatively, if the network address to which the packet is addressed is "1 10.23.43.17," 
then processor 201 cannot learn from routing table cache 203 how to direct the packet and must query 
routing table 104 to learn that the packet is to be transmitted via output port 102-4 (see Table 1). It 
will be clear to those skilled in the art how to perform step 503. 

At step 504, processor 201 transmits each packet and the information on how it should be 
10 routed (/.e., the output port to which it should be routed) to switching fabric 103, which transports it to 
the appropriate port. It will be clear to those skilled in the art how to perform step 504. 

At step 505, processor 201 continually compiles statistics on the temporal succession of 
packets. In particular, processor 201 advantageously counts how many times each entry is needed in a 
short time interval, such as 2 milliseconds, over a longer time horizon, such as 1 second. For example, 
15 processor 201 advantageously knows how many times each entry was needed in each 2 millisecond 
interval during the prior 1 second. Therefore, processor 201 retams a data set (/.e., 500 data points) for 
each destination address. Table 3 depicts an illustrative portion of the information compiled and 
retained in step 505. 



Time 




Address 
110.23.43.17 


Address 
110.23.43.18 




t = 0 




5 


1 




t = -2 ms 




0 


3 




t = -4ms 




5 


0 




t = -6ms 




0 


0 




t = -8 ms 




5 


2 




t = -10ms 




0 


0 




t = -12 ms 




5 


14 




t = -14ms 




0 


4 














t = -998 ms 




5 


12 




t = -1000 ms 




0 


5 





20 Tabfe 3 — 500 Data Points for Destination Addresses 

The purpose of step 505 is to compile data on the need for each needed entry so as to determine if 
patterns can be discerned that can be exploited. For example, an examination of Table 3 reveals a 
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clear pattern of the need for the entry for network address 1 10.23.43.17 (Le,, it is needed in alternating 
2 millisecond intervals) but no such clear pattern is immediately apparent for the entry for network 
address 1 10.23.43.18. But merely because no such pattern is immediately apparent does not mean that 
a real pattern does not exist, and, therefore, the illustrative embodiment employs mathematical tools to 
5 reveal the patterns. 

As part of step 505, processor 201 periodically or sporadically determines the autocorrelation 
for each data set because it provides useful insight into the existence of temporal patterns within each 
data set. When the autocorrelations for each destination address are computed, a strong correlation is 
revealed to exist in some of the data points, which only a weak correlation is indicated in others. The 
10 utility of this difference will be revealed in step 601, which is discussed below. The illustrative 
embodiment computes the autocorrelation for each destination address with a lag of A: = /2/4 = 125. 
The autocorrelation for a data set of n data points, with lag k, is given by: 

N-k 

r,=^ (Eq.l) 

N 

At step 506, processor 201 periodically or sporadically builds a temporal model for the data 
15 set associated with each destination address. In accordance with the illustrative embodiment, and as 
shown in FIG. 6, the building of the temporal model comprises two stages: 

1 . the segregation stage, and 

2. the determination stage. 

At step 601, the segregation stage, the illustrative embodiment determines which of the data 
20 sets (whose autocorrelation was computed in step 505) are highly con*elated and which are not. To do 



this, processor 201 determines a confidence band equal to 2 



, where n is the number of data 



points {e.g., 500) in each data set. After the autocorrelation function for all lags are computed, then 
the mean of the autocorrelation functions is also computed. If the mean for a data set is greater than or 
equal to the confidence band, the illustrative embodiment considers that data set to be highly 
25 correlated; otherwise it considers it to be not highly correlated. 

At step 602, the determination stage, the illustrative embodiment selects a temporal model 
structure for each data set associated with each destination address. In other words, the illustrative 
embodiment seeks to select the temporal model structure for each data set that best predicts the fixture 



-9 of 14 



A.A. Bahattab 1 



occurrence of the destination address associated with the data set. In accordance with the illustrative 
embodiment of the present invention, processor 201 builds one temporal model based on the highly 
correlated data sets to predict the occurrence of all destination addresses whose data sets are highly 
correlated and builds one temporal model based on the not-highly correlated data sets to predict the 
5 occurrence of all destination addresses whose data sets are not-highly correlated. 

For the highly correlated data sets, the illustrative embodiment uses the autoregressive 
moving-average model (1,2) structure 

W, = 0,w^_, - e,a,_, - ©2a,„2 + a, (Eq. 2) 

and for the not highly correlated data sets, the illustrative embodiment uses the autoregressive moving- 
10 average model (1, 3) structure 

W, = 0,w,_, - @,a,_, - 02a,_2 - @^a,_^ + a, (Eq. 3) 

where Wt is the value of the data point in a series after subtracting the mean of the series, <1> is the 
autoregressive parameter, which describes the effect of unit change in Wt.i on Wt, 0 is the moving 
average parameter, the number (2 or 3) refers to the number of moving average parameters, and at is 

15 the white noise error. 

It will be clear to those skilled in the art, however, that in alternative embodiments of the 
present invention other temporal model structures can be used. For example, one temporal model 
structure can be used for all of the data sets which obviates the necessity for computing autocorrelation 
of each data set and of categorizing each data set based on its correlation value. Furthermore, it will 

20 be clear to those skilled in the art how to categorize each data set into two or more categories and to 
select different temporal model structures for each category. And still furthermore, it will be clear to 
those skilled in the art how to choose different temporal model structures than those shown above. 

Next, processor 201 builds a temporal model for each of a randomly selected number {e.g., 10 
to 20) of destination addresses that have highly correlated data sets and for each of a randomly 

25 selected number (e.g., 10 to 20) of destmation addresses that do not have highly correlated data sets. 
The reason that only a few models are built is because can be too computationally burdensome for 
processor 201 to build a different temporal model for each data set, and at least one of the temporal 
models that are built are likely to provide an acceptable model for the other data sets. In alternative 
embodiments of the present invention, processor 201 builds a unique temporal model for each data set. 

30 It will be clear to those skilled in the art how to determine the number of models built given the 
computational resources available. 
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Next, processor 201 selects one temporal model from the dozen or so that were built in step 
602 to use with all of the data sets that are highly correlated and one temporal model from the dozen or 
so that were built in step 602 to use with all of the data sets that are not highly correlated. To chose 
the best model for each group of data sets, the illustrative embodiment advantageously uses the mean 
5 absolute error (MAE). This is done by determining which model does the best job of predicting the 
occurrence of not only its own fiiture addresses, but also the best job of predicting the occurrence of 
the future addresses of the other addresses for which models were built in step 602. The best model is 
the one that in general has the lower values of mean absolute error for the data of the other addresses. 

At the end of step 506, one temporal model is advantageously selected for predicting the 
10 occurrence of addresses associated with highly correlated data sets and a second temporal model is 
advantageously selected for predicting the occurrence of addresses associated with not highly 
correlated data sets. 

At step 507, processor 201 periodically or sporadically repopulates routing table cache 203 
based on the temporal models built in step 506 and on the entries in routing table 104. To accomplish 

15 this, processor 201 advantageously uses the model for the highly correlated data sets to predict the 
number of occurrences of each destination address in the next time interval (i.e., 2 milliseconds). If 
the model predicts that the destination address will be needed in the next time interval, processor 201 
retrieves the entry for that destination address from routing table 104 and populates routing table cache 
203 with that entry. If the model does not predict the occurrence of that destination address in the next 

20 time interval, then processor 201 does nothing. 

If, after processor 201 has predicted the occurrence of each destination address associated with 
the highly correlated data, there is space in routing table cache 203 processor 201 next uses the model 
for the not highly correlated data sets to predict the number of occurrences of each destination address 
in the next time interval (/.e., 2 milliseconds). If the model predicts that the destination address will be 

25 needed in the next time interval, processor 201 retrieves the entry for that destination address from 
routmg table 104 and populates routing table cache 203 with that entry. If the model does not predict 
the occurrence of that destination address in the next time interval, then processor 201 does nothing. 
The reason processor 201 populates routing table cache 203 with the highly correlated data first is 
because if there isrft room in routing table cache 203 for both the highly correlated data and the not 

30 highly correlated data, the highly correlated data sets should have priority. 

To ameliorate interruptions, routing table cache 203 should comprises two portions, one of 
which is active and being used for routing packets and the other which is inactive and being populated 
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in accordance with step 507. This enables the predicted entries to be populated in the inactive portion 
and to switch that portion to active at the appropriate time. 
After step 507, control returns to step 502. 

It is to be understood that the above-described embodiments are merely illustrative of the 
present invention and that many variations of the above-described embodiments can be devised by 
those skilled m the art without departing from the scope of the invention. It is therefore mtended that 
such variations be included within the scope of the following claims and their equivalents. 

What is claimed is: 
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1 1. A router comprising: 

2 an input port for receiving a succession of packets, wherein each of said packets comprises a 

3 destination address; 

4 a plurality of output ports; 

5 a switching fabric for interconnecting said input port to each of said pluraHty of output ports; 

6 a processor or building a temporal model of the occurrence of said destination addresses at 

7 said input port, for populating said routing table cache based on said temporal model and at least one 

8 entry that is stored in a routing table, and for routing at least one of said packets from said input port to 

9 one of said output ports through said switching fabric based on said entry that is stored in said routing 
10 table cache. 

1 2. The router of claim 1 wherein said temporal model is based on the autoregressive moving 

2 average of the occurrence of said destination addresses. 

1 3. A method comprising: 

2 receiving a temporal succession of packets at an input port, wherein each of said packets 

3 comprises a destination address; 

4 generating a temporal model based on the occurrence of said destination addresses; 

5 populating a routing table cache based on said temporal model and at least one entry that is 

6 stored in a routing table; and 

7 forwarding at least one of said packets from said input port to one of a plurality of output ports 

8 based on said entry that is stored in said routing table cache. 

1 4. The method of claim 3 wherein said temporal model is based on the autoregressive moving 

2 average of the occurrence of said destination addresses. 
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Abstract 

1 A router and method for routing table cache population technique is disclosed. In particular, 

2 the illustrative embodiment routes packets through it more quickly than comparatively expensive 

3 routers in the prior art. The present invention recognizes that a fast router has small routing table cache 

4 that has a high hit ratio and that a high hit ratio can be achieved with a small routing table cache by 

5 predicting which entries will be needed in the routing table cache in the future and by populating the 

6 routing table cache with those entries before they are needed. The illustrative embodiment of the 

7 present invention comprises: an input port for receiving a succession of packets, wherein each of the 

8 packets comprises a destination address; a plurality of output ports; a switching fabric for 

9 interconnecting the input port to each of the plurality of output ports; a processor or building a 

10 temporal model of the occurrence of the destination addresses at the input port, for populating the 

1 1 routing table cache based on the temporal model and at least one entry that is stored in a routing table, 

12 and for routing at least one of the packets from the input port to one of the output ports through the 

13 switching fabric based on the entry that is stored in the routing table cache. 
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FROM : PbdullaK Bahattab III CKicago PHONE NO. : 312 3264529 



ftug. 06 2000 12: 11PM P2 
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IN THE UNI TED STATES 
PATENT AND TRADEMARK OFFICE 



I>eclaraiion and Power oi' Attorney 



As the below named invenior, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name. 

I believe I am the original, first and sole inventor of the subject matter which is claimed 
and Ibr which a patent is sought on the invention entitled PREDICTJI VE ROUTING TABLE 
CACHE POPULATION the specification of which is attached hereto. 

I hereby state that I have reviewed and understand the contents of the above identified 
specification, incl^iding the claims, as amended by an amendment » if any, specifically referred to 
in this oath or declaration. 

I acknowledge tlic duty to disclose all infoimation known to me which is material to 
patentability as defined in Title 37, Code of Federal Regulations, 1.56. 

I hereby claim the benefit under Title 35, United States Code, 1 19(c) of any United Slates 
provisional application(s) identified below: 



1 hereby claim foreign priority benefits under Title 35, United States Code, 119 of any 
foreign appHcation(s) for patent or inventors certificate listed below and have also identified 
below any foreign application for patent or inventor's certificate having a filing date before that 
of the application on which priority is claimed; 



J hereby claim the benefit under Title 35, Unired States Code, 120 of any Linitcd States 
applicatjon(s) listed below and, insofar as ihc subject matter of each of the claims of this application is 
not disclosed in the prior United States application in the manner provided by the first paragraph of Title 
35, United States Code, 1 12, 1 acknowledge the duty to disclose all information known to me to be 
material to patentability a$ defircd in Title 37, Code of Federal Regulations, 1 .56 which became 
available between ihc filing date of the prior application and the national or FC'J" international filing date 
of this application: 



T hereby declare tliat all statements made herein of my own knowledge are tnie and that all 
statements made on information and belief are believed to be true; and further that these statements were 
made with the knowledge that willful false sialemcnts and the like so made are punishable by fme or 
imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful 
false statenieni$ may jeopardize the validity of the application or any paienit issued thereon. 

I hereby appoint the following attorneys with full power of substitution and revocation, to 
prosecute said appHcatiori, to make alterations and amendments therein, to receive the patent, and to 
transact al) business in the Patent and Trademark Office connected ihcrcwiith; 



Provisional application No. 60/208,888, filed on June 2, 2000. 



None 



None 



Jason Paul DeMont 
Wayne Breyer 



(Reg. No. 35,7^>3) 
(Reg. No. 38,089) 
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Full namcof sok inventor: AWullah Ali Bahattab 

Inventor s signature 

Residence' Chicago, Cook County, Illinois 
Citizenship: Saudi Arabia 

Post Office Address: 3100 S. Michigan Avenue, Apt. #902 
Chicago, IL 60616 

Telephone calls should be made to Jason Paul DeMont at: 
Phone No.: 908-903-1255 
Fax No. : 908-903-I256 

Please addiess all correspondence to; 



CttStomer Number 22897 



Jason Paul DeMont 
DeMont & Breyer, L.L.C. 
P.O. Box 437 

Basking Ridge, NJ 0792Q-0437 
908-903-1255 
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